草庐IT

iOS 多线程1 --任务与队列

全部标签

ruby-on-rails - Rake RSpec 任务未显示

我有一个继承的应用程序,在Ruby1.9的Rails3上运行,它工作正常,但出于某种原因,当我同时安装rspec和jasmine时,当我运行rake-T时,它们的rake任务都没有出现。该应用程序的Rakefile只是标准文件,事实上,当我安装Cucumber时,它的rake任务显示得很好。如果我输入rakespec,没有错误,但我的specs都没有运行。但是,如果我输入rspecspec,它们都会运行,就好了。Jasmine任务出错,说没有这样的任务。知道为什么这些不会出现,但其他任务会出现吗? 最佳答案 你们开发组有rspec-

ruby - 在 Ruby on Rails 中,将 rake 任务和测试文件的辅助函数放在哪里?

在我的Rails应用程序中,我有一个文件sample_data.rb里面/lib/tasks以及我的/spec中的一堆测试文件目录。所有这些文件通常具有共同的功能,例如:defrandom_address[Faker::Address.street_address,Faker::Address.city].join("\n")end我应该把那些辅助函数放在哪里?在这方面有某种约定吗?感谢您的帮助! 最佳答案 您可以创建一个带有静态函数的静态类。这看起来像这样:classHelperFunctionsdefself.random_ad

线程池七个参数的含义

说一下线程池七个参数的含义?所谓的线程池的7大参数是指,在使用ThreadPoolExecutor创建线程池时所设置的7个参数,如以下源码所示:publicThreadPoolExecutor(intcorePoolSize,intmaximumPoolSize,longkeepAliveTime,TimeUnitunit,BlockingQueueworkQueue,ThreadFactorythreadFactory,RejectedExecutionHandlerhandler){}这7个参数分别是:corePoolSize:核心线程数。maximumPoolSize:最大线程数。kee

多线程问题:为什么不应该使用多线程读写同一个socket连接?

问题的产生经典的单reactor多线程模式采用的是用主线程处理连接事件以及socket读写事件,业务逻辑的处理则是让线程池里的线程各自竞争处理。既然多线程这么方便,为什么不让线程池里的线程也参与到read和send这个过程中呢?在发送数据的过程中,即使TCP的发送缓存满了,我们也可以记录下当前成功发送了多少字节,然后再次注册一个EPOLLOUT事件,只需等待下次可写事件,继续让子线程发送数据即可,岂不是美哉?解释陈硕大佬的解释对于TCP,通常多线程读写同一个socket是错误的设计,因为有shortwrite的可能。假如你加锁,而又发生shortwrite,你是不是要一直等到整条消息发送完才解

ruby - ruby 一次可以运行的线程数是否有限制?

如果不是,那么在保持高效的情况下,最大值是多少?我正在创建14个线程,每个线程都会打开一个URL列表(大约500个),为每个线程创建一个新线程,然后下载它,并将其添加到MySQL数据库中。MySQL池大小设置为50。这是RoR中的一个rake任务。使用Kernal#fork或其他方法会更好吗? 最佳答案 require'open-uri'a='http://www.example.com'*30arr=a.split('')arr.each_slice(3)do|group|group.mapdo|site|Thread.newdo

ruby - 实现 Ruby 的 IO.popen() 和 system() 的替代品

Ruby中的IO.popen()和system()严重缺乏一些有用的功能,例如:获取函数的返回值同时捕获stdout和stderr(单独和合并)在不产生额外的cmd.exe或/bin/sh进程的情况下运行Python有一个模块“subprocess”,我正在考虑将其用作Ruby中类似模块的灵感。现在回答问题:Ruby程序员如何解决上述问题,例如在执行popen()调用时获取返回值?这是否已经实现? 最佳答案 看看标准的Ruby库open3.这将使您能够访问标准输入、标准输出和标准错误。还有一个名为open4的外部项目,它允许您在不使

ruby-on-rails - Rake:记录任何正在执行的任务

如何在不更改任务源的情况下为每个rake任务创建数据库日志记录?我需要存储日期时间、任务名称、参数。是否有某种观察者等? 最佳答案 你可以覆盖application.rb中的Rake::Task#invoke方法:#application.rbmoduleRakeclassTaskalias_method:origin_invoke,:invokeifmethod_defined?(:invoke)definvoke(*args)logger=Logger.new('rake_tasks_log.log')logger.info"#

ruby - ruby 如何完成这项任务(Ruby 中不区分大小写的字符串搜索和替换)?

我在用Ruby替换字符串时遇到一些问题。我的原文:人之所为不如兽之所为。我想替换为:==What==humandoesisnotlike==what==animaldoes.我在使用gsub时遇到区分大小写的问题。(例如,什么,什么)我想保留原始文本。有什么解决办法吗? 最佳答案 如果我理解正确,这就是你想要做的:puts"Whatthehumandoesisnotlikewhatanimaldoes.".gsub(/(what)/i,'==\1==')输出==人类所做的==不同于==动物所做的。

ruby-on-rails - 在 Rails 中旋转后台任务

为Rails应用程序创建后台任务的首选方法是什么?我听说过Starling/Workling和优秀的ol'script/runner,但我很好奇哪种正在成为满足这一需求的实际方式?谢谢!澄清:我喜欢后台Rake的想法,但问题是,我需要持续运行或每10小时运行一次的东西。我不会奢侈地等待Web请求,它需要由服务器启动,与我网站上发生的事件异步。 最佳答案 RyanBates制作了三个可能真正对您有帮助的精彩截屏视频:RakeinBackgroundStarlingandWorklingCustomDaemon他谈到了使用每一种方法的各

ruby - 如何从 ruby​​ 线程获取错误消息

我现在遇到了一个问题,我无法看到我的子线程在哪里吐出错误消息,这使得调试变得困难。例如:Thread.new{a=1/0}有什么方法可以在标准错误中打印出所有线程错误吗? 最佳答案 将Thread类的abort_on_exception标志设置为true。或者,将线程主体包裹在throw/catchblock中,并将异常转储到catch中。 关于ruby-如何从ruby​​线程获取错误消息,我们在StackOverflow上找到一个类似的问题: https:/